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A communications network (200) may include a translation server (202) containing a NGPN-to-HLR mapping table. Translation 
servers (TS) may be configured in several ways. The server or several TSs may be on the network. When a number of translation servers 
are used, a VLR (128) or other network entity receiving an NGPN determines which translation server contains the mapping for that NGPN. 
One way to do this is when a subscriber roams out of his "home" region, his NGPN is presented to the "foreign" service provider's TS. The 
foremg TS broadcasts a query to all other TSs in the network either simultaneously or in stages. Another way is that a VLR receiving a 
NGPN performs a hash function of the NGPN. The hash function indemifies a translation server. The VLR may then query the translation 
server and obtain the NGPN-to-HLR mapping. Where a hash function is used, an extendable hash function to accomodate the addition of 
new TSs without changing the VLR operating systems. 
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METHOD AND APPARATUS SUPPORTING 
NON* GEOGRAPHIC TELEPHONE NUMBERS 

5 BACKGROUND OP THE INVENTION 
Field of the Inv ention 

The present invention relates to wireless communications 
and, more particularly, to a method and device for identifying 
the location of subscriber information for a portable 
10 communications device (such as a portable telephone) user 
using a non- geographic number as the only identifying 
information. 

Discussion of Background Art 

Most wireline telephone numbers are geographic telephone 

15 numbers. For example, a fixed communications device, such as 
a wireline telephone, facsimile (fax) machine, personal 
computer or the like, has a telephone number with an area 
code. The area code and the next three numbers of the 
telephone number (the exchange) contain geographic location 

20 information to allow a call directed to the geographic number 
to be properly channeled through the long distance telephone 
lines (which may be owned and/or operated by a long distance 
service provider) to the proper local telephone lines (which 
may be owned and/or operated by a different, local telephone 

25 service provider) . 

Many wireless communications devices, such as cellular 
telephones, also have geographic telephone numbers. Because 
the communications device is portable, it may not always be 
located in the geographic area indicated by the area code. 

3 0 The exchange may identify a wireless communications service 
provider. These geographic telephone numbers do, however, 
provide sufficient information about the wireless subscriber 
to successfully connect a call. 

Fig. 1 is a greatly simplified illustration of a wireless 

35 communications network, called a Personal Communications 
System (PCS) network 100, The PCS is similar to other types 
of wireless networks and is described to provide background to 
the following discussion of the invention; it is not intended 
by any means to limit the invention to use with PCS systems. 
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Indeed, a person skilled in the art will readily appreciate 
that the invention may be used in many types of communications 
systems and is particularly suitable for use in wireless 
communications systems. The PCS 100 includes a signaling 
network 102, which supports a switched communications network. 
A switched communications network may be, for example, a 
public switched telephone network (PSTN) or an Integrated 
Signaling Digital Network (ISDN) . The signaling network 102 
is connected to a wireless communications system 104. 

An illustrative signaling network 102 includes (among 
other things) a network database 105, which may be a service 
control point (SCP) . A database called a Home Location 
Register (HLR) 106 is part of the signaling network. The HLR 
106 is connected via link 108 to a Regional Signaling Transfer 
Point (RSTP) 110. The RSTP 110 is connected via a number of 
links 112 to several Local Signaling Transfer Points (LSTPs) 
114. Each LSTP 114 is connected via a number of local links 
116 to a number of switches such as Service Switching Points 
(SSP) 118. The SSP 118 connects to customer premises to 
provide for premises equipment, such as a wireline telephone 
120. An SSP 118 may also connect to one or more Wireless 
Switching Centers (WSC) , Mobile Switching Centers (MSC) , or 
Radio Port Control Units (RPCU) 122, which are part of the 
wireless communications system 104. The WSC (or MSC or RPCU) 
122 is connected to a number of Base Stations (BS) (or Radio 
Ports (RP) ) 124, which monitor a "cell" (or "coverage area") 
126 . One or more WSC 122 are connected to a second database 
called the Visiting Location Register (VLR) 128. 

The HLR 106 contains a database maintained by a user's 
local telecommunications service provider at the user's home 
location. This database includes information about the user, 
called the user profile. The VLR 128 is maintained by a 
telecommunications service provider at the location the 
portable device user and portable device 130 are visiting. 
The portable device 130 may be a wireless telephone, a 
personal digital assistant (PDA) having wireless communication 
applications, or other device. The VLR 128 stores a subset of 
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the HLR 106 user information, and records that the portable 
device 13 0 is currently located in the area serviced by that 
VLR. The HLR 106 keeps a record of the VLR in which the 
portable device is currently located. When the portable 
5 device 130 travels to an area covered by a different WSC 122, 
the device is registered in the new WSC 122. The new location 
is stored in the VLR 128. If the portable device 130 travels 
to an area covered by another VLR 128, the subset of the HLR 
106 data stored in the previous VLR is transferred to the new 

10 VLR. The location of the new VLR is stored in' the HLR and the 
previous VLR location is deleted from the HLR 106. 

Wireless communications services are provided by wireless 
communications service providers, which may or may not also be 
local telephone service providers. Some wireless services, 

15 such as proposed PCS service, do not use geographic telephone 
numbers. Such telephone numbers, called non-geographic 
(tele) phone numbers or NGPN, do not contain the information 
identifying the subscriber's signaling network database, which 
contains, for example, the service provider's HLR containing 

20 the subscriber's user profile. They also do not contain the 
information necessary to identify the service provider serving 
that subscriber, from which the identity of the signaling 
network database may be obtained. 

Each wireless service provider may have one or more HLRs. 

25 Moreover, a service provider may need to add HLRs as it 
obtains additional subscribers when the current HLR(s) have 
run out of storage space or the current HLR(s) cannot 
efficiently process information for all of the subscribers 
contained in the existing HLRs. Also, a service provider may 

30 have HLRs located in a number of geographic locations to 
reduce communications costs to subscribers having home 
locations in those geographic regions. 

One currently proposed manner in which the appropriate 
signaling network database is identified from a NGPN is Global 

3 5 Title Translation (GTT) . GTT is performed by the local and 
regional signaling transfer points and translates a 
subscriber's NGPN to the identity of the appropriate HLR 106 
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for that subscriber. These signaling transfer points' main 
function is to handle call setup and calls. Use cf the LST? 
and RSTP resources to perform the NGPN translation ties up 
valuable signaling resources. 
5 In addition to the drawback of STP resource usage, GTT 

may not be practical in future communications systems. This 
is because future communications systems may use asynchronous 
transfer mode (ATM) networks as the wireline communications 
network. GTT may not be used because an ATM network will use 

10 the same physical network for transmitting signaling messages 
used to set up calls and for transmitting the calls 
themselves. (Currently, signaling messages are sent on a 
signaling network separate from the voice trunk network.) 
Because the same network will be used for call set up and the 

15 actual data transmission, signaling transfer points will not 
be used in the network, and therefore GTT will not be 
available. 

NGPN translation may be required in many situations. 
Three of these situations are: 

20 (1) When a subscriber travels from an area covered by a 

first VLR into an area covered by a second VLR, the 
HLR must be updated so that calls may be routed to 
the proper location. The subscriber's HLR needs to 
be identified in order to update the user profile. 

25 (2) When a call is directed to the subscriber having a 

NGPN, the translation is used to locate the HLR so 
that (a) the portable device may be located, and (b) 
call delivery options such as call forwarding or 
call screening may be obtained. 

30 3) When a subscriber having a NGPN originates (places) 

a call, the translation may be used to identify the 
subscriber's HLR so that authentication information 
and service profile information (such as billing 
information, long distance carrier, etc.) may be 

35 obtained. 
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The NGPN translation process is initiated when an NGPN is 
presented to a network entity in one of the above situations. 
The network entity may be a VLR, SSP, STP, or other 
"intelligent" network entity. For simplicity, the 

5 specification generically assumes the NGPN is presented to a 
VLR . It should be understood that any "intelligent" network 
entity may be suitable. 

A practical NGPN translation method should meet several 
criteria. First, it should be fast and efficient. Second, 

10 the translation should be able to be' performed by widely 
distributed network entities, such as VLRs, SSPs, or SCP 
serving the caller. Third, the translation method should be 
scalable to handle an increase in the number of subscribers 
and signaling databases using NGPNs . Fourth, the translation 

15 method should be flexible so that changes in the NGPN-to-HLR 
mapping (such as a subscriber changing service providers, two 
service providers merging into a single company, the HLR 
becomes saturated, a subscriber moves to a different 
geographic location, etc.) may be made dynamically, without 

20 halting the service provider's operation. It may also be 
desirable for a NGPN translation scheme to permit an 
independent entity, such as a Numbering Plan Administrator, to 
chose NGPNs for subscribers without considering how the 
numbers will map to HLRs (i.e., without regard to service 

25 provider, geographic location, etc.). 

Therefore, it is an object of the present invention to 
provide a NGPN translation system that may be used in the 
absence of signaling transfer points or other entity 
performing GTT. 

30 It is a further object of the present invention to 

provide a NGPN translation system that is fast and efficient. 
It is yet another object of the present invention to 

provide a NGPN translation system that may be performed by 

widely distributed network entities. 
35 It is an even further object of the present invention to 

provide a NGPN translation system that is scalable. 
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It is yet even another object of the present invention tc 
provide a NGPN translation system that permits dynamic changes 
to the mapping. 

It is yet even a further object of the present invention 
5 to provide a NGPN scheme that allows an independent entity tc 
assign numbers without regard to HLR mapping. 



SUMMARY OF THE INVENT £gN 

These and other objects of the present invention are 

10 provided by translation servers added to the communications 
network. A translation server is a network entity that 
contains a NGPN- to -HLR mapping table. 

Translation servers (TS) may be configured in several 
ways. In a first preferred embodiment, the translation server 

15 is a single, centralized translation server. A VLR queries 
the central TS to obtain the appropriate HLR address. In a 
second preferred embodiment, a number of translation servers 
may be distributed in the signaling network. 

When a number of translation servers are used, a VLR 

20 receiving an NGPN should be able to determine which 
translation server contains the mapping for that NGPN. This 
may be done in several ways. In a first preferred embodiment, 
a subscriber that has roamed out of his "home" region serviced 
by his service provider, will have his NGPN presented to the 

25 TS of a service provider at his current location (a "foreign" 
service provider) . The foreign TS may broadcast a query to 
all other TSs in the signaling network either simultaneously 
or in 9tages. In a second preferred embodiment, a VLR 
receiving a NGPN performs a hash function on the NGPN. The 

30 hash function identifies a translation server. The VLR may 
then query the translation server and obtain the NGPN -to- HLR 
mapping. 

Where a hash function is used, one preferred embodiment 
uses an extendable hash function to accommodate the addition 
3 5 of new TSs without changing the VLR operating systems. In 
another embodiment of the translation servers identified with 
hash functions, further additional TSs are accommodated by a 
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two stage TS. A VLR forms a first hash function. If a TS has 
split into a number of TSs, the split TS performs a second 
hash function to determine the location of the TS having the 
requested NGPN-to-HLR mapping. 
5 The present invention may also be used where a subscriber 

uses different service providers for different communications 
services, such as voice, data, and/or video service. Other 
applications for the present invention are also possible, such 
as cell relay address translation, Internet and domain. name 
10 translations, 800 number translation, and local telephone 
number mobility. 

BRIEF DESCRIPTION OF THE DRAWINGS 

The present invention is described with reference to the 
15 following figures: 

Fig. 1 is a diagram of an illustrative wireless communications 
system; 

Fig. 2 is a block diagram of a high-level architecture of a 
communications system having a translation server according to 
20 the present invention; 

Fig. 3 is a block diagram of a communications system having a 
VLR which determines the translation server address using hash 
functions, according to one embodiment of the present 
invention; 

2 5 Fig. 4 is a block diagram of a communications system having a 

VLR which determines the translation server address using hash 
functions and has a cache memory, according to one embodiment 
of the present invention; 

Figs. 5A and SB illustrate extendible hashing as used in the 
30 present invention; and 

Fig. S illustrates an architecture for a communications 
network having a translation server according to another 
embodiment of the present invention; 

Fig. 7 is a block diagram of a communications system having a 

3 5 VLR which determines the translation server address for a 

subscriber having more than one communications service, 
according to one embodiment of the present invention; and 

7 
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Fig. 8 is a block diagram of a communications system having a 
VLR which determines the translation server address for a 
subscriber having more than one communications service, 
according to another embodiment of the present invention. 

5 

DETAILED DESCRIPTION OF PREFERRED EMBODIMENTS 

This description assumes that the NGPN is presented from 
a switching center, such as a MSC (or RPCU) 122 or a wireless 
switching center to a VLR. The VLR obtains the NGPN- to-HLR 
10 mapping, either by performing the translation; or determining 
the translation from other entities in the network. 

The Translation Server 

One embodiment of the present invention is to provide a 
translation server (TS) configured to perform a NGPN- to-HLR 

15 mapping. The TS may be a separate network entity, it may be 
distributed along the communications network in a number of 
entities, or it may be located in another network entity, such 
as a HLR or VLR. 

Fig. 2 illustrates a high-level architecture of a 

20 communications system 200 having a translation server 202 
according to the present invention. Fig. 2 shows the TS as a 
separate network entity, but it need not be a separate entity. 
When a NGPN is presented to a VLR 128 by a SSP 118, the VLR 
has a pointer or performs a hash function (described below) 

25 which directs the number to the TS 202. The TS includes a 
database, such as a look-up table, which receives the NGPN and 
maps it to the appropriate HLR 106. This mapping may be a 
standard file or database search and may be performed in any 
number of ways obvious to a person skilled in the art. If the 

30 NGPN- to-HLR mapping has to be changed for any reason (i.e., 
subscribers are added, deleted, or changed, for example) , only 
the TS -- not the VLRs should be updated. This is much 
simpler to accomplish. One reason for this is that a large 
number of VLRs are distributed throughout a communications 

3 5 network; here, only the TS 202 needs to be updated, rather 
than a large number of network entities (VLRs) . 
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There may be a TS 202 associated with each HLR 106. On 
the other hand, it may be preferable to provide a single, 
centralized translation server 202. When a switch receives a 
NGPN, it 'forwards it to the VLR 128. The VLR queries the 
5 central TS (zhe call will be held at the switch until it 
receives further instructions) to obtain the appropriate HLR 
address. The VLR then queries the HLR to determine how to 
route call. One possible drawback of the single, centralized 
TS is that as the number of NGPNs grows, the TS may not be 
10 able to handle the processing demands. One way to alleviate 
this problem is to use a parallel database processing machine 
as the TS. 

Another way to alleviate this problem is to use a cache 
memory 204 at the VLRs, as seen in Fig. 2. Each VLR may have 

15 an associated cache memory 204 which will maintain a number of 
recently called NGPNs and the associated HLR addresses. When 
an NGPN is received by a VLR, it will compare the received 
NGPN with the NGPNs in memory; if the NGPN is stored in the 
cache memory 204, the HLR address is already available, and 

20 the TS need not be queried. If the NGPN is not stored in the 
cache memory, the VLR queries the TS and obtains the 
appropriate HLR address. The NGPN and HLR address may be 
stored in the cache memory and, if necessary (e.g., if the 
cache is full) , another NGPN and identifier (perhaps the least 

25 recently U9ed NGPN) is deleted from the cache memory 204 . 
Alternatively (or in addition) , the TS 202 may have a cache 
memory 206. 

Where a cache is used, information stored in the cache 
may become invalid if the NGPN-to-HLR mapping is changed. 

3 0 Several alternatives exist for insuring that the information 
in the cache is eventually updated. In one alterative, the 
cache is not immediately updated when the mapping is changed ; 
instead, when the VLR queries the HLR indicated in the cache, 
the HLR returns a message indicating that the mapping is not 

35 found. The VLR then uses the usual non-caching procedure for 
querying the appropriate TS as before. A person skilled in 
the art recognizes other alternatives are equally suitable. 
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Alternatively, a network may have a number of TSs. For 
example, each service provider may maintain its own TS 202. 
Each TS maintains the NGPN-to-HLR mapping for the subscribers 
to that service provider. (If a service provider has only one 
5 HLR, a TS may not be required because no NGPN-to-HLR napping 
is necessary.) This allows each service provider to store its 
subscriber information separately from other service 
providers. The maintenance of the TS information becomes 
decentralized. When a subscriber changes service providers, 
10 the subscriber's NGPN is deleted from one TS and added to 
another . 

With this alternative, a system should be provided for 
the case where a subscriber roams outside of a service 
provider's "home" region (the geographical region served by 
15 the service provider) into a "foreign" region. When an NGPN 
is presented to a foreign MSC or RPCU 122, the NGPN may be 
forwarded to the foreign service provider's TS. The foreign 
service provider's TS obtains the appropriate HLR address 
using one of the following methods: 
20 1. The foreign TS broadcasts a query to all other TSs. 

This may be done in a single, parallel broadcast or 
in a chain of queries. The "home" TS sends the 
foreign TS the NGPN-to-HLR mapping. 
2. A combination of broadcast and other schemes. For 
25 example, broadcasts may be made in stages , with 

certain TSs queried first. The TS queried by each 
stage may be determined on a variety of criteria, 
such as a service provider's total number of 
subscriber, geographic location with respect to the 
30 inquiring TS, etc. 

This method is equally applicable to any multiple TS 
configuration, regardless of who maintains each TS. 

Some decrease in processing time may be achieved by 
caching at either the VLR of the TS. As described above, a 
3 5 cache is a limited memory containing all of the NGPN 
translation information for a number of recently accessed 
numbers . 
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Translation Servers Using Hashing Functions 

Fig. 3 is a block diagram of a communications system 3 00 
having a network entity, such as a VLR 128' , which determines 
the TS identification using hash functions. The system 
includes a wireless switching center 122 (or MSC or RPCU) , a 
VLR 128' having a hash function processor 304, a TS address 
table 306 , one or more TSs 202, and a number of HLRs 106. 

The HLR address for a NGPN may be found in the following 
manner. When a NGPN translation is desired (such as call 
origination, call termination, or VLR handdff ) , the NGPN is 
presented to a switch SSP 118, WSC, MSC, or RPCU 122. The 
switch holds the call and forwards the NGPN to a VLR 128'. 
The VLR receives the NGPN at an input 302 and forwards it to 
the hash function processor 3 04. The VLR performs a hash 
function (described in more detail below) on the NGPN, 
preferably to a binary representation of the NGPN, to obtain 
a value f (NGPN) , where f is a hash function. 

The hash function result typically is not a network 
address. If it is not, the function result may be sent to a 
TS mapping table 306. The TS mapping table contains a table 
of hash function results and associated TS addresses. The TS 
mapping table receives the NGPN and obtains the appropriate TS 
address. Once the TS address is obtained, the VLR 128 r 
queries the identified TS to determine the HLR address for the 
NGPN. This may be done by forwarding the NGPN to the TS. The 
TS looks up the identifier of the HLR serving that NGPN and 
forwards it to the VLR. The VLR contacts the identified HLR 
and continues the call set up. After the call is set up, the 
call is connected from the switch. 

To implement this architecture, the VLR operations 
support system will load hash functions, manage the NGPN- to - 
HLR mapping, and provide other administrative functions (if 
any) for supporting the translation scheme. 
Tfrff Ha^fr Fifflgtipa 

Hash functions are well known. For the present 
invention, two desirable traits of a hash function are (1) 
easy computation; and (2) maps roughly the same number of 
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NGPNs to each TS. 

One example of a simple hash function for a system having 
two TSs is the function evenO. This function returns, for 
example, a result of 0 if the NGPN ends in a 0 or even number 
5 (note that the binary representation of an even number ends in 
a 0) and a result of 1 if the NGPN ends in an odd number (the 
binary representation of an odd number ends in a 1) . Thus, in 
this example, NGPNs ending in an even number are stored in a 
first TS and NGPNs ending in an odd number are stored in a 

10 second TS, This hash function satisfies both criteria above, 
provided that the amount of NGPN telephone numbers ending in 
even and in odd numbers are relatively equal . 

Other hash functions are known. See, for example, D. 
Knuth, The Art of Compute r Programming, Vol. 3, Sorting and 

15 Searching , Chapter 6, section 6.4, Addison-Wesley 1973. The 
contents of that document are incorporated herein by 
reference. Examples of some hash functions that may be used 
in the present invention are: 

• The mod hash function: The hash function f is 
2 0 determined by dividing the NGPN by the number of TSs 

(t) in the system. The result is the value NGPN mod 
t. When using a mod function, t is typically 
selected to be a prime number. This allows the 
number of TSs to be increased in intervals of prime 
25 numbers (1, 3, 5, 11, 13, 17, 19 etc.). 

• The "middle square" function: The hash function f 
is determined by the NGPN, a positive integer r, and 
the number of TSs (t) in the system. The value of 
t should lie between 1 and 2 r . Let p be a number 

30 representing the middle r bits of the binary 

representation of the square of the NGPN. The 
result is the value p mod t. The value of t does 
not need to be a prime number. 

• The "folded sum" function: The hash function f is 
35 determined by the NGPN and the number of TSs t in 

the system. The function partitions the 

representation of the NGPN into several portions and 
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adds these portions to obtain a value p (for 
example, NGPN 500-555-1234 may become 
5 + 0+0 + 5+5+5 + 1+2+3+4 = 30) . The result is the value p 
mod t. The value of c does not need to be a prime 

5 number . 

The hash function chosen should be selected according to the 
number of TSs in the system and the manner in which the NGPNs 
are selected and assigned. A person skilled in the art 
readily appreciates that, depending on the implementation, 

0 other hash functions may also be suitable. 

As discussed above, the hash function result typically is 
not a network address that may be used directly with the 
signaling network. One way to convert the hash result into a 
network address is to load a mapping table 306 into each VLR. 

5 For example, in the even () hash function described above, the 
mapping table 306 may have a table that maps hash result 0 to 
a first TS network address and hash result 1 to a second TS 
network address. This mapping table will be the same for all 
VLRs and will need updating only if a new TS (rather than a 

0 new subscriber or HLR) is added to the network. 

A second way to convert the hash result into a network 
address is to reserve a block of consecutive network addresses 
for TSs, ranging from TS_low to TS_high, and generate the 
network TS address as TS_low + f (NGPN) . 

5 Caching NQPN Tranalatlona 

As seen in Fig. 4, the VLR 128'' is the same as VLR 128' 
of Fig. 3 but also includes a cache memory 402. As described 
above, caching may reduce the number of times a VLR queries 
the TS server by storing HLR addresses for recently requested 

0 NGPNs. If a VLR 128' ' is presented with a NGPN for the first 
time, it performs the hash function, converts the result into 
a network address, and queries the TS for appropriate HLR 
address. The NGPN and associated HLR addresses are stored in 
the cache. If a NGPN is presented to that VLR 128'' , a search 

5 of the cache memory 402 is performed to determine if the HLR 
mapping for the number is stored in the cache. If it is (a 
"cache hit"), there is no need to query a TS for that 
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information and the HLR may be queried. If the information is 
not stored in the cache memory 402 (a "cache miss") , the hash 
result is sent to the TS mapping table 308, as described 
above . 

5 A number of cache memory management schemes are known. 

Because the size of a cache memory is intended to be limited, 
once the memory is filled, there should be a memory management 
system to determine which entries remain and which entries are 
purged from the cache memory. A Least Recently Used scheme 

10 may be used, for example, wherein the least recently used NGPN 
is replaced by a new NGPN. A person skilled in the art 
recognizes that other cache memory management schemes may be 
equally suitable for use in the invention. 

The size of the cache memory 402 may be selected 

15 according to the VLR or TS in which the cache is intended to 
be used. For example, frequently queried VLRs or TSs may have 
a larger cache memory than less frequently queried VLRs or 
TSs. 

Translation Server Maintenance Operations 

20 To maintain up-to-date information in a TS, it should be 

possible to add or delete a subscriber from a TS and to change 
a subscriber from one HLR to another. As the number of 
subscribers grows, additional HLRs and TSs may become 
necessary. In order for the TS servers to maintain up-to-date 

25 information, it should also be possible to add an HLR to the 
system, split the subscribers of one HLR into two (or more) 
HLRs, and split the subscribers on one TS into two (or more) 
TSs. 

Examples of how each of these operations is performed is 
3 0 described: 

Add a Subscriber : When a new subscriber is being added 
to the system, a service profile is created for the subscriber 
and stored in an appropriate HLR. The hash function is 
performed on the NGPN to determine in which TS the HLR address 
35 associated with the NGPN is to be located. The proper TS is 
then updated and receives the NGPN -to -HLR mapping information 
for that subscriber. 
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Delete g Subscriber : When a subscriber is being 
terminated from the system, the hash function is performed on 
the NGPN to determine in which TS the HLR address associated 
with the NGPN is stored. The TS is searched to find the 
5 subscriber's NGPN and the associated HLR information. The 
record for the NGPN-to-HLR mapping for that NGPN is deleted 
from the TS. The subscriber's user profile may then be 
deleted from the HLR. 

Move a Subscriber To a New HLR : When a subscriber is 

10 being moved to a new HLR, the hash function is performed on 
the NGPN. The TS is determined and queried to find the 
current HLR address. The subscriber information is updated to 
the new HLR and the TS entry for that NGPN is then updated tc 
reflect the new HLR address. 

15 To Add a New HLR ': When a new HLR is being added having 

substantially all new subscribers, when a new subscriber is 
added to the new HLR, the same procedure for adding a 
subscriber to an existing HLR is performed. The new NGPN and 
HLR address are added to the TS. 

20 Splitting an HLR : An HLR having h records is to have n 

{where n < h) new subscribers added to it. However, h + n 
records exceeds the HLR' s capacity. Thus, a new HLR is 
required to accommodate the new subscribers . A new HLR should 
be installed in a manner that each HLR has roughly the same 

25 number of NGPN records. Thus, each HLR should hold about (h 
+ n) /2 records. 

After the new HLR is established, the (h - n) /2 records 
to be moved are copied into the new HLR. The TS entries for 
existing NGPNs that were moved to the new HLR are updated as 

30 described above. After the user profiles are stored in the 
new HLR, these records are deleted from the old HLR. 

Alternatively, the old HLR may copy the (h - n)/2 
addresses to the new HLR, perform the hash function of these 
numbers, and store the results on a table. After all of the 

35 numbers are hashed, the table entries are forwarded to the 
respective TSs to update the HLR information. The numbers 
moved to the new HLR are deleted from the old HLR. 
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Splitting a TS: When a new TS is required (for example, 
if the number of NGPNs is too large for the current TSs to 
process efficiently) , the entries in the current TSs may need 
to be redistributed into a greater number of TSs. This will 
require a change in the hash function, because one or more new 
TS identifiers will exist. Because the hash functions change, 
each VLR in the system changes its hash function processor 304 
to process the new hash function. It is preferable to 

reduce the VLR modification time to reduce VLR "down time". 
Also, it is preferable to change the hash function in a manner 
so that only a variable of the existing hash function is 
changed, rather than changing the function itself. In this 
way, the VLRs do not need to be reprogrammed (which is time 
and cost intensive) , but can be updated by changing a value in 
a data file, which may be simply and quickly performed. 

Assume : 

(1) each VLR in the system performs a first hash 
function £ which it uses to map a NGPN to a TS; and 

(2) the total number of TSs is to be increased from t to 
t + 1, and the contents of one existing TS is to be 
modified. 

One way in which this may be done that meets the two preferred 
criteria above (limit down time and change data, not function) 
is to use a dynamic hashing called extendible hashing. 
Extendible hashing is discussed in R. Fagin, J. Nievergelt, N. 
Pippenger, and H.R. Strong, "Extendible Hashing A Fast 
Access Method For Dynamic Files" , ACM Trans. Database Sys., 
vol. 4, no. 3, pp. 315 - 44 (Sept. 1979) . The contents of 
that document are incorporated herein by reference. 

In extendible hashing, the hash function returns a value 
that is a string of bits, but only k of these bits are used in 
determining the TS address. The k bits are used to look up 
the TS identifier in the TS mapping table 306 in the VLR 128. 
For example, if there are two TSs, k may be 1 and one bit (for 
example, the most significant bit (MSB) or least significant 
bit (LSB) ) may be looked at to determine the TS address. In 
this example, the LSB is looked at. If the LSB is 0, a first 
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TS is identified; and if the LSB is 1, a second TS is 
identified. 

When the number of TSs is increased from t to t - 1, the 
value of k is increased to Jc + 1. That is, the next bit is 
5 also looked at in determining the TS address. Using the 
example above, the new k value is increased to 2; the two 
least significant bits are looked at to determine the TS 
address . 

Extendible hashing as used in this invention is 

10 illustrated in Figs. 5A and 5B. As seen in Fig. 5A, if k = 1, 
the TS mapping table has 2* * 2 rows. The first row contains 
the network address of TS1 and the second row contains the 
network address of TS2 . The LSB of f (NGPN) is looked at to 
determine which TS the NGPN-to-HLR mapping may be found. If 

15 the LSB is 0, a first TS is identified; and if the LSB is 1, 
a second TS is identified. 

Suppose TS1 is split into TS1 and a new TS3 . The value 
of k increases to 2, so the number of rows in the TS mapping 
table increases to 2 k = 4 rows, as seen in Fig. 5B. The two 

20 LSB of the hash function result are used to determine the TS 
address. (The LSB is looked at before the second LSB. A hash 
function "10" is 01 on f [k] , because the hash function is 
read from right to left . ) The TS mapping table contains the 
address for TS1 in the first row, but now includes an address 

25 for TS3 in the new second row. In this example, half of the 
NGPNs previously mapped to TS1 are now mapped to TS3 . Rows 
three and four both contain the address for TS2, so the 
remaining half of the NGPNs continue to be mapped to TS2. 

An example of a preferred procedure for splitting a TS 

30 is: 

(1) for each NGPN stored in the TS to be split, the hash 
function is applied and the (Jc + l)th bit is 
examined. If the bit is 0, the record remains in 
the current TS; otherwise, it is copied into the new 
35 TS; 
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(2) increase the value of k in all VLRs and update the 
TS mapping table to include the new TS identifier; 
and 

(3) all of the records copied into the new TS are 
5 deleted from the old TS . 

Scalable Transl ation Servers Using Hashing Functions 
Using the extendible hashing described above where a TS 
is added to the network, the k value and TS address are 
changed in each VLR . It may be desirable to have a scalable 

10 TS scheme that does not require data in each VLR to be 
modified when a TS is added to the network. Fig. 6 
illustrates an architecture for a communications network 600 
having such a scheme. The VLR 128"' is preferably the same 
as shown in Fig. 3 or Fig. 4. The difference occurs in the TS 

15 202' when it is split. 

In this embodiment, when a TS is added or split, instead 
of changing the hash function k value, another level is added 
to the existing TS. As seen in Fig. 6, assume that TS2 is 
approaching its memory capacity and adding a new TS becomes 

20 desirable. TS2 is split into TS2.1 (602') and TS2.2 (602''). 
These new TSs are not addressable by the VLRs , but through TS2 
202'. 

A second hash function g is performed by a TS hash 
processor 604 on all of the NGPNs directed to TS2 . The 

25 results of this second hash function determine if the NGPN 
mapping information remains in the original TS (now renamed 
TS2.1) or moved to the new TS, named TS2.2. 

When an NGPN is received by a VLR 128' ' , it processes the 
hash function f in the usual manner. When the TS address 

30 obtained from the TS mapping table 304 is for TS2, the NGPN is 
sent to TS2, also in the usual manner. When the NGPN is 
received by TS2, the TS hash processor 604 performs second 
hash function g. The hash results are presented to a TS 
internal mapping table 606. The results of the mapping table 

35 determine if the NGPN-to-HLR information is stored in TS2.1 or 
TS2.2. The NGPN is directed to the proper TS, and the 
information is looked up and returned to the VLR 128'''. A 
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cache memory 608 may be used by TS2.1 to avoid querying the TS 
hash processor 604 and TS internal mapping table 606 for 
recently requested NGPNs. 

If either TS2.1 or TS2.2 is to be split, this method may 
5 be repeated to create a third level. Several repetitions of 
this method may # however, eventually result in a long chain of 
TSs, requiring the calculation of many hash functions. At 
some point, the time to obtain the translation causes an 
unacceptable delay in call set up time. Alternatively, the 
10 extendible hashing described above may be used in the second 
level TSs (e.g., TS2 . 1 and TS2.2). That is, hash function g 
is extended by increasing the number of bits looked at by the 
hashing function. This alternative has the following 
advantages : 

15 (1) no more than two levels of TS are created and no 

more than one TS lookup is made; 
(2) the extendible hashing is performed only by TSs 
running out of capacity; other TSs remain 
unaffected; 

2 0 (3) the extendible hashing is easier to apply: the 

changes in k and the TS mapping tables are made in 
the TS only, not in each VLR; and 
(4) different TSs may use different hash functions g, if 
desired. 

25 The present invention may be used where a subscriber uses 

a number of communications services. Each service may or may 
not be provided by a different service provider. In the 
future, a subscriber may use different service providers for 
receiving different communication services, such as voice 

3 0 communications, data communications, and video or mult i -media 

communications. Preferably, the translation is performed by 
adding a service code (SO to the NGPN and maintaining a 
mapping table containing addresses for the HLR for each of the 
subscriber ' s services . 
3 5 Fig. 7 is a block diagram of a communication system 700 

having a VLR 128''' which determines the translation server 
address for a subscriber having more than one communication 
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service, according to one embodiment of the present invention. 
Each service provider may maintain a separate database (such 
as an HLR) containing a user profile for the subscriber. a 
call or registration may involve consulting a different HLR 
depending on the communications service desired. 

When a NGPN is presented to a VLR (or other suitable 
network entity) for call delivery, origination, or 
registration, it is accompanied by a service code describing 
the type of service requested. For example, voice may be 0 
("00"), data may be 1 (-01-), and video or multi-media may be 
2 ("10") . This service code is non-geographic because it does 
not identify the service provider, but only identifies the 
service type. The hash function processor 304 hashes the NGPN 
as described above and queries the identified TS . The query 
15 contains not only the NGPN, but the service code. The TS 702 
contains an NGPN- to- HLR mapping to the appropriate HLR 
according to the requested service. Thus, the TS 702 uses a 
combination of the NGPN and service code to return the address 
of the database belonging to the appropriate service provider. 
20 Fi 9- 8 is a block diagram of a second embodiment of a 

communication system 800 having a VLR 126' ' ' ' which determines 
the translation server address for a subscriber having more 
than one communication service. As seen in Fig. 8, the TS 802 
contains an NGPN- to -HLR mapping for only a single HLR, 
25 regardless of the service requested. The TS 802, returns the 
HLR address to the VLR, and the VLR queries this HLR, called 
the "main" HLR 804. The query to the main HLR 804 contains 
the NGPN and SC. The main HLR contains a mapping for the 
service code to the address of the appropriate HLR 806 or 
30 other database for the requested service. 

A person skilled in the art recognizes that the TS and 
cache maintenance operations can be readily modified to 
accommodate this application. 

Other Application for the Invention 
35 Cffll B»1*Y Address Translation 

The dynamic hashing scheme described above may be used in 
the interconnection of ATM and cell relay systems, such as 

20 
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public cellular communications systems. When a person having 
an ATM enterprise network (such as a local area network (LAN) ; 
places a call to be delivered on a cell relay system, there is 
a mismatch' in the addressing used by the two networks. For 
5 example, a typical ATM LAN may have a customized, private 
address numbering system unique to that LAN; public cell relay 
systems typically have a uniform address numbering system , 
such as the E.164 numbering plan. 

A translation server as described above may be used to 

10 establish an interface between an ATM enterprise network to 
communicate with a cell relay system. This may allow, for 
example, e-mail to be sent to and from an enterprise network 
to a wireless PDA. The translation server translates between 
LAN addresses and cell relay system addresses, so thaz 

15 communications may be' forwarded to the correct locations. 
Internet and Dop ^™ tt*»i ^ e Translations 
The dynamic hashing scheme described above may also be 
used in the interconnection of private enterprise networks 
using Internet addressing and a network using another 

20 addressing system, such as E.164. 

There are two types of Internet addresses. The first is 
the domain name (such as H user@company . com" ) , the second is 
the IP address, which is a 12 or 16 digit number associated 
with an Internet gateway. 

25 Both the current and proposed (IPv6) Internet addressing 

systems are Internet access provider-based. If a customer 
changes providers (i.e., changes from America On Line to 
Prodigy), the user's domain name changes (i.e., from 
usertool.com to user@prodigy . com) as well as his IP address. 

3 0 A translation server may be provided to permit a person 
already having Internet access through a first access provider 
to a change to a second access provider, without changing his 
Internet IP address and/or his domain name. Internet 
communications may be routed through one or more TSs, as 

3 5 described above, and the communications may be sent to the 
intended recipient regardless of the address provided by the 
Internet access provider. Thus, it is possible to provide 
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Internet users with universal domain names and/or IP 
addresses . 

Local Tele phnn* Mn™ K e r Portability 

Local phone number portability is the ability for a 
5 wireline telephone service customer to change geographic 
locations, yet keep the same phone number the customer had at 
the previous location. This is particularly beneficial for 
businesses. A change in geographic location, for example, 
from New York City to New Jersey, may involve a change in 

10 geographic location (changing the telephone number area code 
and exchange, e.g., from 212-xxx-xxxx to 201-xxx-xxxx) , and a 
change in local telephone service provider (e.g., from NYNEX 
to New Jersey Bell) . 

One suggested method for providing local number 

15 portability is to route calls to a database, such as a 
translation server in the communications network. These 
translation servers may be accessed, identified, and managed 
using the present invention. 

RQO Number portability 

20 The present invention may used for 800 number 

portability, such as when a subscriber wishes to retain the 
same 800 number when changing service providers. Currently, 
every service provider maintains the 800 number translation 
for all 800 numbers, even those belonging to other service 

25 providers. It may be desirable to eliminate this method, 
particularly if there is an increase in the number of 8 00 
number service providers and 800 numbers. The current method 
may be replaced with the present invention. The present 
invention allows 800 number portability in the same manner as 

30 it allows local telephone number portability. 

Several embodiments of translation servers are described, 
each having unique advantages. 

Translation servers have several advantages over other 
35 methods of translating NGPNs. The NGPN-to-HLR mapping 
information for a NGPN is located in one or more network 
entities, but preferably not in network signaling or switching 

22 
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components whose resources are better used in setting up and 
maintaining calls. Moreover, signaling transfer points are 
not used, so ATM signaling networks may be used with the TSs . 
This location advantage provides easy modification and 
5 efficient storage, and does not require modifications to each 
VLR when subscribers are added, deleted, or changed. A TS may 
be located in a single convenient location or distributed 
throughout the network. A single, centralized translation 
server is fast. It may, however, become too large to 
1C efficiently process the number of received translation 
requests . 

A number of TSs distributed through a network is not as 
fast as a centralized TS, but each TS may handle only a 
fraction of the total mapping requests. Using a number of TSs 

15 identified with the ' use of a hash function has several 
advantages. The time to perform other routine maintenance 
operations (adding, deleting, or changing a subscriber's 
record) is also acceptable. Also, the translation may be made 
with a minimum of signals exchanged between the VLR and the 

20 TS. Time consuming or difficult operations, such as splitting 
a HLR or TS, are performed infrequently. 

Identifying the TS using a hash function has a 
scalability advantage, as described. Using dynamic hashing 
lends it9elf to easy scalability. The two- level NGPN 

25 translation scheme has the advantage of scalability without 
changes in the VLRs. 

The present invention satisfies all of the objects of the 
invention. It may be used in signaling networks without 
signaling transfer points. It is fast and efficient. The 

3 0 translation may be performed by widely distributed VLRs and 
TSs. It is scalable and permits dynamic changes. Because the 
numbers do not need to contain information about the 
subscriber's geographic location or service provider, the 
invention permits portable device numbers to be assigned by an 

35 independent entity. 
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A person skilled in the art understands that the 
invention may be used with communication systems other than a 
PCS having an ATM backbone. For example, although a PCS 
system was disclosed, it is understood that PACS, cellular, cr 
5 other wireless communication system may also be used. The 
above described embodiments of the invention are intended tc 
be illustrative only. Numerous alternative embodiments may be 
devised by those skilled in the art without departing from the 
spirit and scope of the following claims. 
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Appendix A 

Glossary of Acronyms 

A XM Asynchronous Transfer Mode 

BS Base Station 

5 HLR Home Location Register 

Gtt Global Title Translation 

ISDN Integrated Signaling Digital Network 

LAN Local Area Network 

LSB Least Significant Bit 

10 LSTP Local Signaling Transfer' Point- 
MSB Most Significant Bit 
MSC Mobile Switching Center 
NGPN Non- Geographic Telephone Number 
PCs Personal Communications System 

15 PDA Personal Digital Assistant 

RP Radio Port 

RPCU Radio Port Control Unit 

PSTN Public Switched Telephone Network 

RSTP Regional Signaling Transfer Point 

20 SC Service Code 

SCP Service Control Point 

SSP Service Switching Point 

TS Translation Server 

VLR Visiting Location Register 

25 WSC Wireless Switching Center 
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We claim: 

1. A method for mapping non- geographic portable device 
numbers (NGPN) to a signaling network device address, 
comprising the steps of : 

a. generating a table containing NGPNs and associated 
signaling network device addresses; 

b. presenting a NGPN to the table; and 

c. obtaining the signaling network device address for 
the presented NGPN. 

2. The method of claim 1, wherein the step of presenting the 
NGPN to the table further comprises the steps of: 

a. receiving the NGPN at a network entity; and 

b. forwarding the NGPN to the table. 

3. The method of claim 1, wherein the step of presenting the 
NGPN to the table further comprises the steps of broadcasting 
the NGPN to a number of tables in the signaling network. 

20 4. The method of claim 3, wherein the step of broadcasting 
comprises simultaneously broadcasting the NGPN to the number 
of tables in the signaling network. 

5. The method of claim 3, wherein the step of broadcasting 
25 comprises broadcasting the NGPN in a number of stages, each 

stage broadcasting the NGPN to fewer than all of the number of 
tables in the signaling network. 

6. The method of claim l, wherein the step of presenting the 
30 NGPN to the table further comprises: 

a. performing a hash function on the NGPN; 

b. using a result of the hash function, obtaining a 
signaling network address for the table. 

35 
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7. The method of claim 6, wherein che step of obtaining the 
signaling network address for the table further comprises 
using the hash function result to look up the table address on 
a mapping table . 

8. The method of claim 6, further comprising the step of 
selecting the hash function to be an extendible hash function. 



10 9. The method of claim 1, further comprisihg the steps of: 

a. before presenting the NGPN to the table, checking a 
cache memory for the signaling network device 
address for the presented NGPN; 

b. if the signaling network device address for the 
15 presented NGPN is not in the cache memory, 

presenting the NGPN to the table. 

10. The method of claim 1, wherein the step of obtaining the 
signaling network device address for the presented NGPN 

20 further comprises the steps of: 

a. checking a cache memory for the signaling network 
device address for the presented NGPN; 

b. if the signaling network device address for the 
presented NGPN is not in the cache memory, obtaining 

25 the NGPN from the table. 

11. The method of claim 1, wherein a service code is added to 
the NGPN, and the method further comprising presenting the 
service code to the table. 

30 

12. The method of claim 1, wherein a service code is added to 
the NGPN, the step of obtaining the signaling network device 
address further comprising; 

a. obtaining from the table a signaling network device 
3 5 address for a main network device; and 
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b. obtaining from the main network device a signaling 
network device address for the presented NGPN and 
service code. 

13. A method for splitting a first translation server (TS) , 
containing non-geographic number records, on a signaling 
network into two translation servers including a new TS, 
wherein network devices obtain an address for existing TSs 
using a dynamic hashing function, the method comprising the 
steps of: 

a. applying the dynamic hash function on each non- 
geographic number -contained in the first TS; 

b. using the result of the hash function, determining 
which number records will remain in the first TS and 
which number records will be moved to the new TS; 

c. copy onto the new TS the number records to be moved; 
and 

d. deleting from the first TS the copied records. 

14. The method of claim 13, wherein the dynamic hash function 
is an extendible hash function which looks at k bits of the 
hash function result, further comprising the steps of: 

a. the step of determining further comprising examining 
the ik + l)th bit in determining which number 
records will be moved; 

b. increasing the value of k in the network devices 
obtaining an address for existing TSs using a 
dynamic hashing function; and 

c. updating the network devices obtaining an address 
for existing TSs to include the new TS. 

15. A method for splitting a first translation server (TS) , 
containing non-geographic number records, on a signaling 
network into two translation servers including a new TS, 
comprising the steps of: 

a. applying a dynamic hash function on each number in 
the first TS; 
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b. using the result of the hash function, determining 
which number records will remain in the first TS and 
which number records will be moved to the new TS; 

c. copy onto the new TS the number records to be moved; 
and 

d. deleting from the first TS the copied records. 



16. The method of claim 15, wherein the dynamic hash function 
is an extendible hash function which looks at k bits of the 
hash function result, further comprising the -steps of: 

a. the step of determining further comprising examining 
the (k + l)th bit in determining which number 
records will be moved; and 

b. increasing the value of k in the first TS . 

17. A translation server (TS) for mapping a non- geographic 
number to a signaling network entity, comprising: 

a. an input configured to receive the non-geographic 
number; 



b. a table responsive to the input and containing non- 
geographic numbers and corresponding signaling 
network entity addresses. 

18. The TS of claim 17 # further comprising a cache memory 
connected between the input and the table. 

19. The TS of claim 17, further comprising: 

a - at least two tables containing non- geographic 
numbers and corresponding signaling network entity 
addresses ; 

b. a TS server hash processor connected to the input; 
and 

c. a TS internal mapping table connected to an output 
of the hash processor and containing a mapping of 
hash processor results with an address of one of the 
at least two tables. 
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20. The TS of claim 19, wherein the hash processor is 
configured to process an extendible hash function. 



21. A signaling network entity for forwarding non-gecgraphic 
5 numbers to a translation server, comprising: 

a. an input configured to receive the non-gecgraphic 
number; 

b. - a hash processor responsive to the input; and 

c. a table connected to an output of the hash processor 
10 and containing translation server network addresses 

corresponding to hash processor results. 

22. The entity of claim 21, further comprising a cache memory 
connected between the input and the hash processor. 
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